CLAIMS 

We cteim: 

1 . i^wnethod of routing a net within a particular region of an integrated circuit 
("IC") layout, the net having a set of pins, the method comprising: 

a) ^partitioning the particular IC region into a plurality of sub-regions, 

'■ ; \ 

wherein the sub-regionsMiave the same shape; and 

b) identifying a route that connects a set of sub-regions containing the 
pins of the net, wherein the route has a route edge that is at least partially diagonal. 

2. The method of\claim 1, wherein identifying the route includes identifying 

\\ 

the set of sub-regions that contains the pins of the net. 



3. The method of cteim 2, wherein identifying the route further includes 

ft /' 

using the identified set of sub-regions to retrieve' the route from a storage structure. 



4. The method of claim 1», wherein all the sub-regions have the same size. 

- \\ 
I \ 

5. The method of claim 1, wherein each sub-region is a four-sided sub- 

/ \ 

region. v \ 

•■■\ 

6. The method of claim 1, wherein a plurality of paths exist between the sub- 
regions, wherein a plurality of the paths are diagonal paths, wherein the route traverses at 

s " ' ' ■ * 

\\ 

least one of the diagonal paths. v, 
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7. The method of claim 6 wherein identifying the route comprises identifying 
the paths between the sub-regions used by the route. 



8. The method of claim 7, wherein a plurality of the paths are Manhattan 
paths, wherein the route traverses at least one of the Manhattan paths. 

9. The method of claim 1, wherein a plurality of inter-region edges exist 

between the sub-regions, wherein a plurality of the inter-region edges between the sub- 

/ 

• / 

regions are diagonal inter-region edges, wherein the route intersects at least one of the 

. ... , . - f i 

it * 

diagonal inter-region edges. / : 

10. The method of claim 9, wherein identifying the route comprises 



identifying the inter-regioh edges between the sub-regions intersected by the route. 

vj. • 

11. The method of claim 10, wherein a plurality of the inter-region edges 

between the sub-regions; are Manhattan inter-region edges, wherein the route intersects at 

\ f I 

least one of the Manhattan inter-region edges. 

12. The methocl of cl^m 1 further comprising: 

w \ 

a) computing a cost for the route; 

b) determining whether to embed the route based on the computed 

cost. 

13. The method of claim 1, wherein the IC region is the layout of the entire IC. 
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14. The i|>uting method of claim 1, wherein the IC region is a portion of the 
layout of the entire IC. 

15. A method of routing a set of nets within a region of an integrated circuit 

1 

("IC") layout, wherein each net includes a set of pins in the region, the method 

1 

comprising: ^ 




partitioning the IC region into several sub-regions; 




for each particular net in the region, 



identifying each sub-region that contains a pin from the set of pins 



of the particular net, and 



identifying a xoute that connects the identified sub-regions for the 




particular net; 



wherein some/offthe identified routes have route edges that are at least 

/ I 




partially diagonal. 



16. The method of claim ! 5, 



wherein a plurality of paths exist between the sub-regions, and a plurality 
of the paths are diagonal paths, 
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wherein identifying the route for each particular net comprises identifying 



the paths used by a se| of interconnect lines connecting the sub-regions identified for the 
particular net, 



wherein some of the interconnect lines traverse some of the diagonal 

\ 

paths. 



17. The method of claim 16, wherein a plurality of the paths are Manhattan 
paths, wherein some of the interconnect lines traverse some of the Manhattan paths. 

18. The method of claim 16 further comprising embedding each route by 
storing the identity of the paths used by each route. 

1 9. The method of claim 15, 

wherein a plurality of inter-region edges exist between the sub-regions, 

and a plurality of the inter-region edges are diagonal, 

/' \ ■ ■ 

wherein identifying the route for each particular net comprises identifying. 

the inter-region edges intersected by a set of interconnect lines connecting the sub-regions 

identified for the particular net, 

wherein some of the interconnect lines intersect some of the diagonal 
inter-region edges. 
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20. The method of claim 19, wherein a plurality of the inter-region edges are 
Manhattan edges, wherein some of the interconnect lines intersect some of the Manhattan 
inter-region edges. 

21. The method of claim 19 further comprising embedding each route by 
storing the identity of the inter-region edge intersected by each route. 

22. The method of claim 15 further comprising: ,. 

for each particular net in the region, identifying a set of route that connects 
the identified sub-regions for the particular net; 

computing costs for the identified routes; 

selecting one identified route for each net based on the computed costs; 

embedding the selected route for each net in the region. 

/ 

/ 

23. A computer readable medium comprising a computer program having 
executable code, the computer program for routing a net within a particular region of an 
integrated circuit ("IC") layout, the net having a plurality of pins, the computer program 
comprising: 

a) a first set of instructions for partitioning the particular IC region 
into several sub-regions; 
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b) ^ a second set of instructions for identifying a route that connects a 

set of sub-regions containing the pins of the net, wherein the route has a route edge that is 

\ 

at least partially diagonal 

24. The computer readable medium of claim 23, 

wherein a plurality of paths exist between the sub-regions, and a plurality 
of the paths are diagonal, 

wherein the second set of instructions includes a third set of instructions 
for identifying the paths between the sub-regions used by the route; 

wherein the route traverses at least one of the diagonal paths. 

25. The computer readable medium of claim 23, 

wherein a plurality of inter-region edges exist between the sub-regions, 
and a plurality of the inter-region edges are diagonal, 

wherein the second set of instructions includes a third set of instructions 
for identifying the inter-region edges between the sub-regions intersected by the route; 

wherein the route traverses at least one of the diagonal inter-region edges. 

26. The computer readable medium of claim 23 further comprising: 

a) a third set of instructions for computing a cost for the route; 
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V; 



* 



b) a fourth: set of instructions for determining whether to embed the 

V 



route based on the computed^cpst. 
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